/**
 说明: 登录流程
 1. 收集表单项数据
 2. 前端验证
 1) 验证用户信息(账号，密码)是否合法
 2) 前端验证不通过就提示用户，不需要发请求给后端
 3) 前端验证通过了，发请求(携带账号, 密码)给服务器端
 3. 后端验证
 1) 验证用户是否存在
 2) 用户不存在直接返回，告诉前端用户不存在
 3) 用户存在需要验证密码是否正确
 4) 密码不正确返回给前端提示密码不正确
 5) 密码正确返回给前端数据，提示用户登录成功(会携带用户的相关信息)
 */
import request from '../../utils/request'

Page({

    /**
     * 页面的初始数据
     */
    data: {
        phone: '', // 手机号
        password: '',// 用户密码
        verify: ''//验证码
    },

    /**
     * 生命周期函数--监听页面加载
     */
    onLoad: function (options) {

    },

    // 表单项内容发生改变的回调
    handleInput(event) {
        // let type = event.currentTarget.id;// id传值 取值： phone || password
        let type = event.currentTarget.dataset.type; // data-key=value
        // console.log(event);
        this.setData({
            [type]: event.detail.value
        })
    },


    // 登录的回调
    async regist() {
        // 1. 收集表单项数据
        let {phone, password, verify} = this.data;
        // 2. 前端验证
        /*
        * 手机号验证：
        *   1. 内容为空
        *   2. 手机号格式不正确
        *   3. 手机号格式正确，验证通过
        * */

        if (!phone) {
            // 提示用户
            wx.showToast({
                title: '手机号不能为空',
                icon: 'none'
            })
            return;
        }
        // 定义正则表达式
        let phoneReg = /^1(3|4|5|6|7|8|9)\d{9}$/;
        if (!phoneReg.test(phone)) {
            wx.showToast({
                title: '手机号格式错误',
                icon: 'none'
            })
            return;
        }

        if (!password) {
            wx.showToast({
                title: '密码不能为空',
                icon: 'none'
            })
            return;
        }

        if (!verify) {
            wx.showToast({
                title: '验证码不能为空',
                icon: 'none'
            })
        }

        // 后端验证
        let result = await request('/registServlet', {phone, password, verify})
        if (result.code === 200) { // 登录成功
            wx.showToast({
                title: '注册成功'
            })
            // 将用户的信息存储至本地
            wx.setStorageSync('userInfo', JSON.stringify(result.profile))


            // 跳转至登录界面
            wx.reLaunch({
                url: '/login/login'
            })
        } else if (result.code === 400) {
            wx.showToast({
                title: '手机号已存在',
                icon: 'none'
            })
        } else if (result.code === 502) {
            wx.showToast({
                title: '验证码错误',
                icon: 'none'
            })
        } else {
            wx.showToast({
                title: '注册失败，请重新注册',
                icon: 'none'
            })
        }
    },
    /**
     * 生命周期函数--监听页面初次渲染完成
     */
    onReady: function () {

    },

    /**
     * 生命周期函数--监听页面显示
     */
    onShow: function () {

    },

    /**
     * 生命周期函数--监听页面隐藏
     */
    onHide: function () {

    },

    /**
     * 生命周期函数--监听页面卸载
     */
    onUnload: function () {

    },

    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh: function () {

    },

    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom: function () {

    },

    /**
     * 用户点击右上角分享
     */
    onShareAppMessage: function () {

    }
})
